### Embedded Systems

# GPIO Devices Lesson 06

Francesco Menichelli francesco.menichelli@uniroma1.it

#### **GPIO** basic

#### GPIO (General Purpose Input Output)

- Can drive to logical 0 or 1 a specific pin or group of pins
- Can be used for protocol emulation
  - Requires software emulation, i.e. <u>significant CPU load</u>
  - Examples: serial protocol, I2C, pulse generation, etc.
- What logical 0/1 means?
- How software can drive the pin?
  - We need the detailed peripheral description (reference manual datasheet)
- What kind of <u>loads</u> can be connected?
  - We need the electrical specifications (hardware datasheet)



Example: GPIO on PIC16F1648

RA0-RA7

RB0-RB7

#### **GPIO** basic

- Bidirectional ports require at least two registers
  - Data direction register
    - Specify the direction of the port at bit level (e.g. 0=input; 1=output
  - Data register
    - If configured as output Write: output data to external pin; Read: read data from register
    - If configured as input Write: discarded; Read: read data from external pin



Example: Internal GPIO structure in Atmega family

- PA0-PA7
- Drivers, data register, data direction register

#### **GPIO** basic

- GPIO example
  - Output: led drive
  - Input: button press
- How LED resistor is calculated?
- How BUTTON resistor is calculated?



Typical LED forward Current vs. Voltage for two different LED colors



# **GPIO** driving current

- Maximum direct drive current can be derived from hardware datasheet
  - Generally in the order of 10-20 mA
- If more current is needed, a transistor used as switch is a common solution
  - BJT switch
    - Rbase dimensioning (R1)
  - MOSFET switch
    - Rgate dimensioning (R1)





### **GPIO** general circuit example

- The input gate detects whether the input voltage level is low or high by comparing it to a threshold voltage.
- To provide noise immunity and prevent chatter on transitions, the input gate can be configured to act as a Schmitt trigger, with input hysteresis. With hysteresis there are different threshold voltages for rising and falling transitions.
- The output drives to either 3.3V (high) or 0V (low). Drivers are buffering transistors with (relatively) high current driving capability.
- A pull-up/down resistor can be inserted via software configuration bits. The transistors that enable the pull-up/down resistor contribute their appreciable nonlinear resistance to it, so the effective resistance is not constant over the input pin voltage range



#### **GPIO** electrical characteristics

| GPIO input/output pin electrical o            | characteristics                                                                  |
|-----------------------------------------------|----------------------------------------------------------------------------------|
| Output low voltage<br>V <sub>OL</sub>         | < 0.40 V <sup>1</sup> )<br>< 0.66 V <sup>2</sup> )<br>< 0.40 V <sup>3</sup> )    |
| Output high voltage<br>V <sub>OH</sub>        | > 2.40 V <sup>4</sup> )<br>> 2.64 V <sup>5</sup> )<br>> 2.90 V <sup>6</sup> )    |
| Input low voltage<br>V <sub>IL</sub>          | < 0.80 V <sup>7)</sup><br>< 0.54 V <sup>8)</sup><br>< 1.15 V <sup>9)</sup>       |
| Input high voltage<br>V <sub>IH</sub>         | > 2.00 V <sup>10</sup> )<br>> 2.31 V <sup>11</sup> )<br>> 2.15 V <sup>12</sup> ) |
| Hystereses                                    | > 0.25 V <sup>13)</sup><br>0.66 - 2.08 V <sup>14)</sup>                          |
| Schmitt trigger input low threshold $V_{T-}$  | 1.09 - 1.16 V <sup>15)</sup><br>0.9 <sup>16)</sup>                               |
| Schmitt trigger input high threshold $V_{T+}$ | 2.24 - 2.74 V <sup>17)</sup><br>0.90 V <sup>18)</sup>                            |
| Pull-up/down<br>resistance                    | 40 - 65 KΩ <sup>19)</sup><br>100 KΩ <sup>20)</sup>                               |
| Pull-up/down<br>current                       | < 50 uA <sup>21)</sup><br>< 28 uA <sup>22)</sup>                                 |
| Pin capacitance                               | 5 pF <sup>23)</sup>                                                              |
| Bus hold resistance                           | 5-11 KΩ <sup>24)</sup>                                                           |

 Bus-holders are used to prevent CMOS gate inputs from getting floating values when they are connected to tri-stated nets.
 Otherwise both transistors in the gate could get turned on, thus shorting the power supply and ground, which would destroy the CMOS gate.



#### **GPIO** example PIC16F628

FIGURE 5-1: BLOCK DIAGRAM OF RA0/AN0:RA1/AN1 PINS



FIGURE 5-8: BLOCK DIAGRAM OF RB0/INT PIN



# **GPIO** example PIC16F628

| Param. No. Sym Characteristic/Device  VIL Input Low Voltage  I/O ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Min                    | Typ† | Max                  | Unit           |                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------|----------------------|----------------|--------------------------------------------------------------------------------------------------------|
| The state of the s | Vee                    |      |                      | Oill           | Conditions                                                                                             |
| I/O ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Vee                    |      |                      |                |                                                                                                        |
| D030 with TTL buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Vss                    | _    | 0.8<br>0.15 VDD      | V<br>V         | VDD = 4.5V to 5.5V otherwise                                                                           |
| D031 with Schmitt Trigger input <sup>(4)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Vss                    | _    | 0.2 VDD              | V              |                                                                                                        |
| D032 MCLR, RA4/T0CKI,OSC1 (in RC mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Vss                    | _    | 0.2 VDD              | V              | (Note1)                                                                                                |
| D033 OSC1 (in HS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Vss                    | _    | 0.3 VDD              | V              |                                                                                                        |
| OSC1 (in LP and XT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Vss                    | _    | 0.6                  | V              |                                                                                                        |
| VIH Input High Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                        |      |                      |                |                                                                                                        |
| D040 I/O ports with TTL buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2.0V<br>.25 Vpp + 0.8V | _    | VDD<br>VDD           | V<br>V         | VDD = 4.5V to 5.5V otherwise                                                                           |
| D041 with Schmitt Trigger input <sup>(4)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.8 VDD                | _    | VDD                  | ٧              |                                                                                                        |
| D042 MCLR RA4/T0CKI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0.8 VDD                | _    | VDD                  | V              |                                                                                                        |
| D043 OSC1 (XT and LP)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.3                    | _    | VDD                  | V              |                                                                                                        |
| D043A OSC1 (in RC mode)<br>D043B OSC1 (in HS mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0.9 VDD<br>0.7 VDD     | _    | VDD<br>VDD           | V              | (Note1)                                                                                                |
| D070 IPURB PORTB weak pull-up current                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 50                     | 200  | 400                  | μA             | VDD = 5.0V, VPIN = VSS                                                                                 |
| IIL Input Leakage Current <sup>(2), (3)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | •                      |      |                      |                |                                                                                                        |
| I/O ports (Except PORTA)   D060                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | _<br>_<br>_            |      | ±1.0<br>±0.5<br>±1.0 | μΑ<br>μΑ<br>μΑ | Vss ≤ VPIN ≤ VDD, pin at high-impedance<br>Vss ≤ VPIN ≤ VDD, pin at high-impedance<br>Vss ≤ VPIN ≤ VDD |
| D063 OSC1, MCLR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | _                      | _    | ±5.0                 | μА             | Vss ≤ VPIN ≤ VDD, XT, HS and LP oscillator configuration                                               |
| Vol. Output Low Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |      |                      |                |                                                                                                        |
| D080                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                      | _    | 0.6                  | V              | IOL = 8.5 mA, VDD = 4.5 V, -40° to +85°C                                                               |
| I/O ports <sup>(4)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | _                      | _    | 0.6                  | V              | IOL = 7.0 mA, VDD = 4.5 V, +85° to<br>+125°C                                                           |
| Voн Output High Voltage <sup>(3)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                        |      |                      |                |                                                                                                        |
| D090 I/O ports (Except RA4 <sup>(4)</sup> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | VDD - 0.7<br>VDD - 0.7 | _    |                      | V<br>V         | IOH = -3.0 mA, VDD = 4.5 V, -40° to +85°C<br>IOH = -2.5 mA, VDD = 4.5 V, +85° to<br>+125°C             |
| D150 VoD Open-Drain High Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _                      | _    | 8.5*                 | ٧              | RA4 pin PIC16F627A/628A/648A,<br>PIC16LF627A/628A/648A                                                 |

### **GPIO** example PIC registers

TABLE 5-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

| Address | Name  | Bit 7  | Bit 6  | Bit 5              | Bit 4  | Bit 3  | Bit 2  | Bit 2 Bit 1 |        | Value on<br>POR | Value on<br>All Other<br>Resets |
|---------|-------|--------|--------|--------------------|--------|--------|--------|-------------|--------|-----------------|---------------------------------|
| 05h     | PORTA | RA7    | RA6    | RA5 <sup>(1)</sup> | RA4    | RA3    | RA2    | RA1         | RA0    | xxxx 0000       | qqqu 0000                       |
| 85h     | TRISA | TRISA7 | TRISA6 | TRISA5             | TRISA4 | TRISA3 | TRISA2 | TRISA1      | TRISA0 | 1111 1111       | 1111 1111                       |
| 1Fh     | CMCON | C2OUT  | C10UT  | C2INV              | C1INV  | CIS    | CM2    | CM1         | CM0    | 0000 0000       | 0000 0000                       |
| 9Fh     | VRCON | VREN   | VROE   | VRR                | _      | VR3    | VR2    | VR1         | VR0    | 000- 0000       | 000- 0000                       |

Legend:

- = Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition. Shaded cells are not used for PORTA.

TABLE 5-4: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB

| Address   | Name   | Bit 7  | Bit 6  | Bit 5  | Bit 4              | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR | Value on<br>All Other<br>Resets |
|-----------|--------|--------|--------|--------|--------------------|--------|--------|--------|--------|-----------------|---------------------------------|
| 06h, 106h | PORTB  | RB7    | RB6    | RB5    | RB4 <sup>(1)</sup> | RB3    | RB2    | RB1    | RB0    | XXXX XXXX       | uuuu uuuu                       |
| 86h, 186h | TRISB  | TRISB7 | TRISB6 | TRISB5 | TRISB4             | TRISB3 | TRISB2 | TRISB1 | TRISB0 | 1111 1111       | 1111 1111                       |
| 81h, 181h | OPTION | RBPU   | INTEDG | T0CS   | T0SE               | PSA    | PS2    | PS1    | PS0    | 1111 1111       | 1111 1111                       |

Legend: u = unchanged, x = unknown. Shaded cells are not used for PORTB.

# **GPIO** example ATmega

Figure 30. General Digital I/O<sup>(1)</sup>



# **GPIO** example ATmega



# **GPIO** example ATmega - registers

| Port B Data Register – PORTB   |               |        |        |        |        |        |        |        |        |       |
|--------------------------------|---------------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| TOTAL Data Register - TOTAL    | Bit           | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
|                                |               | PORTB7 | PORTB6 | PORTB5 | PORTB4 | PORTB3 | PORTB2 | PORTB1 | PORTB0 | PORTB |
|                                | Read/Write    | R/W    | 1     |
|                                | Initial Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |       |
| Port B Data Direction Register | Bit           | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
| – DDRB                         | Dit           | DDB7   | DDB6   | DDB5   | DDB4   | DDB3   | DDB2   | DDB1   | DDB0   | DDRB  |
|                                | Read/Write    | R/W    | ı     |
|                                | Initial Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |       |
| Port B Input Pins Address –    |               |        |        |        |        |        |        |        |        |       |
| PINB                           | Bit           | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
| 1 1112                         |               | PINB7  | PINB6  | PINB5  | PINB4  | PINB3  | PINB2  | PINB1  | PINB0  | PINB  |
|                                | Read/Write    | R      | R      | R      | R      | R      | R      | R      | R      | 1     |
|                                | Initial Value | N/A    |       |

# **GPIO** example ATmega - registers

- Each port pin consists of three Register bits: DDxn, PORTxn, and PINxn.
- The DDxn bit in the DDRx Register selects the direction of this pin. If DDxn is written logic one, Pxn is configured as an output pin. If DDxn is written logic zero, Pxn is configured as an input pin.
- If PORTxn is written logic one when the pin is configured as an input pin, the pull-up resistor is activated. To switch the pull-up resistor off, PORTxn has to be written logic zero or the pin has to be configured as an output pin.
- If PORTxn is written logic one when the pin is configured as an output pin, the port pin is driven high (one). If PORTxn is written logic zero when the pin is configured as an output pin, the port pin is driven low (zero).
- Independent of the setting of Data Direction bit DDxn, the port pin can be read through the PINxn Register bit.
- PINxn Register bit and the preceding latch constitute a synchronizer. This is needed to avoid metastability if the physical pinchanges value near the edge of the internal clock.

### **GPIO** example ATmega - code

- Set PORT B pins 0 and 1 high, 2 and 3 low, and define the port pins from 4 to 7 as input with pull-ups assigned to port pins 6 and 7.
- Set PORT B pins 0 to 3 as outputs and pins from 4 to 7 as inputs
- The resulting pin values are read back again
- A *nop* instruction is included to be able to read back the value recently assigned to some of the pins

```
unsigned char i;
...
/* Define pull-ups and set outputs high */
/* Define directions for port pins */
PORTB = 0xC3;
DDRB = 0xOF;
/* Insert nop for synchronization*/
_NOP();
/* Read port pins */
i = PINB;
```

### **GPIO** example ST32F

#### GPIO main features

- Up to 16 I/Os under control
- Output states: push-pull or open drain + pull-up/down
- Output data from output data register (GPIOx\_ODR) or peripheral (alternate function output)
- Input states: floating, pull-up/down, analog
- Input data to input data register (GPIOx\_IDR) or peripheral (alternate function input)
- Bit set and reset register (GPIOx\_BSRR) for bitwise write access to GPIOx\_ODR
- Locking mechanism (GPIOx\_LCKR) provided to freeze the I/O configuration
- Analog function

# **GPIO** example ST32F

Analog To on-chip peripheral Alternate function input on/off Input data register Read  $V_{DD\_FT}^{(1)}$ TTL Schmitt Protection registers trigger on/off diode Input driver I/O pin Write data register Bit set/reset Output driver  $V_{DD}$ on/off Protection diode P-MOS Output Output control Read/write N-MOS From on-chip Push-pull, Alternate function output peripheral open-drain or disabled J Ånalog

ai15939b

Figure 16. Basic structure of a five-volt tolerant I/O port bit

### **GPIO** example ST32F

Figure 17. Selecting an alternate function on STM32F401xB/C and STM32F401xD/E



#### I/O port control registers

- Each of the GPIOs has four 32-bit memorymapped control registers (GPIOx\_MODER, GPIOx\_OTYPER, GPIOx\_OSPEEDR, GPIOx\_PUPDR) to configure up to 16 I/Os.
  - GPIOx\_MODER register is used to select the I/O direction (input, output, AF, analog).
  - GPIOx\_OTYPER and GPIOx\_OSPEEDR registers are used to select the output type (pushpull or opendrain) and speed
  - GPIOx\_PUPDR register is used to select the pull-up/pull-down whatever the I/O direction.

GPIO port mode register (GPIOx\_MODER)

Address offset: 0x00

#### Reset values:

- 0x0C00 0000 for port A
- 0x0000 0280 for port B
- 0x0000 0000 for other ports

| 31    | 30                         | 29                       | 28   | 27       | 26           | 25 | 24           | 23 | 22           | 21 | 20          | 19 | 18          | 17      | 16 |
|-------|----------------------------|--------------------------|------|----------|--------------|----|--------------|----|--------------|----|-------------|----|-------------|---------|----|
| MODER | R15[1:0]                   | MODER14[1:0] MODER13[1:0 |      | R13[1:0] | MODER12[1:0] |    | MODER11[1:0] |    | MODER10[1:0] |    | MODER9[1:0] |    | MODER8[1:0] |         |    |
| rw    | rw                         | rw                       | rw   | rw       | rw           | rw | rw           | rw | rw           | rw | rw          | rw | rw          | rw      | rw |
| 15    | 14                         | 13                       | 12   | 11       | 10           | 9  | 8            | 7  | 6            | 5  | 4           | 3  | 2           | 1       | 0  |
| MODE  | MODER7[1:0] MODER6[1:0] MO |                          | MODE | R5[1:0]  | MODER4[1:0]  |    | MODER3[1:0]  |    | MODER2[1:0]  |    | MODER1[1:0] |    | MODE        | R0[1:0] |    |
| rw    | rw                         | rw                       | rw   | rw       | rw           | rw | rw           | rw | rw           | rw | rw          | rw | rw          | rw      | rw |

Bits 2y:2y+1 **MODERy[1:0]:** Port x configuration bits (y = 0..15)

These bits are written by software to configure the I/O direction mode.

00: Input (reset state)

01: General purpose output mode

10: Alternate function mode

11: Analog mode

#### I/O port data registers

- Each GPIO has two 16-bit memory-mapped data registers: input and output data registers (GPIOx\_IDR and GPIOx\_ODR).
- GPIOx\_ODR stores the data to be output, it is read/write accessible.
- The data input through the I/O are stored into the input data register (GPIOx\_IDR), a read-only register.

#### 8.4.6 GPIO port output data register (GPIOx\_ODR) (x = A..E and H)

Address offset: 0x14

Reset value: 0x0000 0000

| 31    | 30       | 29    | 28    | 27    | 26    | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|----------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | Reserved |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
| 15    | 14       | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ODR15 | ODR14    | ODR13 | ODR12 | ODR11 | ODR10 | ODR9 | ODR8 | ODR7 | ODR6 | ODR5 | ODR4 | ODR3 | ODR2 | ODR1 | ODR0 |
| rw    | rw       | rw    | rw    | rw    | rw    | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 ODRy: Port output data (y = 0..15)

These bits can be read and written by software.

Note: For atomic bit set/reset, the ODR bits can be individually set and reset by writing to the  $GPIOx\ BSRR\ register\ (x = A..E\ and\ H).$ 

#### I/O data bitwise handling

- The bit set reset register (GPIOx\_BSRR) is a 32-bit register which allows the application to set and reset each individual bit in the output data register (GPIOx\_ODR). The bit set reset register has twice the size of GPIOx\_ODR.
- To each bit in GPIOx\_ODR, correspond two control bits in GPIOx\_BSRR: BSRR(i) and BSRR(i+SIZE).
- When written to 1, bit BSRR(i) sets the corresponding ODR(i) bit. When written to 1, bit BSRR(i+SIZE) resets the ODR(i) corresponding bit.
- Writing any bit to 0 in GPIOx\_BSRR does not have any effect on the corresponding bit in GPIOx\_ODR. If there is an attempt to both set and reset a bit in GPIOx\_BSRR, the set action takes priority.
- The GPIOx\_BSRR register provides a way of performing <u>atomic</u> <u>bitwise handling</u>.

#### 8.4.7 GPIO port bit set/reset register (GPIOx\_BSRR) (x = A..E and H)

Address offset: 0x18

Reset value: 0x0000 0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| BR15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8 | BR7 | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BR0 |
| w    | w    | w    | w    | w    | w    | w   | w   | w   | w   | w   | w   | w   | w   | w   | w   |
| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| BS15 | BS14 | BS13 | BS12 | BS11 | BS10 | BS9 | BS8 | BS7 | BS6 | BS5 | BS4 | BS3 | BS2 | BS1 | BS0 |
|      |      |      |      |      |      |     |     |     |     |     |     |     |     |     |     |

Bits 31:16 **BRy:** Port x reset bit y (y = 0..15)

These bits are write-only and can be accessed in word, half-word or byte mode. A read to these bits returns the value 0x0000.

0: No action on the corresponding ODRx bit

Resets the corresponding ODRx bit

Note: If both BSx and BRx are set, BSx has priority.

Bits 15:0 **BSy:** Port x set bit y (y= 0..15)

These bits are write-only and can be accessed in word, half-word or byte mode. A read to these bits returns the value 0x0000.

0: No action on the corresponding ODRx bit

1: Sets the corresponding ODRx bit

#### **GPIO** locking mechanism

- It is possible to freeze the GPIO control registers by applying a specific write sequence to the GPIOx\_LCKR register.
- The frozen registers are GPIOx\_MODER, GPIOx\_OTYPER, GPIOx\_OSPEEDR, GPIOx\_PUPDR, GPIOx\_AFRL and GPIOx\_AFRH.
- When the LOCK sequence has been applied to a port bit, the value of the port bit can no longer be modified <u>until the</u> <u>next reset</u>.
- Each GPIOx\_LCKR bit freezes the corresponding bit in the control registers (GPIOx\_MODER, GPIOx\_OTYPER, GPIOx\_OSPEEDR, GPIOx\_PUPDR, GPIOx\_AFRL and GPIOx\_AFRH).

#### I/O alternate function input/output

- Two registers are provided to select one out of the sixteen alternate function inputs/outputs available for each I/O.
- With these registers, it is possible to connect an alternate function to some other pin as required by the application.
- This means that a number of possible peripheral functions are multiplexed on each GPIO using the GPIOx\_AFRL and GPIOx AFRH alternate function registers.

#### **External interrupt/wakeup lines**

• All ports have external <u>interrupt capability</u>. To use external interrupt lines, the port must be configured in input mode.

#### **GPIO** example ST32F - Circuit

#### Input configuration

- The output buffer is disabled
- The Schmitt trigger input is activated
- The pull-up and pull-down resistors are activated depending on the value in the GPIOx\_PUPDR register
- The data present on the I/O pin are sampled into the input data register every AHB clock cycle
- A read access to the input data register provides the I/O State



Figure 18. Input floating/pull up/pull down configurations

#### **GPIO** example ST32F - Circuit

#### **Output configuration**

- The output buffer is enabled:
  - Open drain mode: A "0" in the Output register activates the N-MOS whereas a "1" in the Output register leaves the port in Hi-Z (the P-MOS is never activated).
  - Push-pull mode: A "0" in the Output register activates the N-MOS whereas a "1" in the Output register activates the P-MOS
- The Schmitt trigger input is activated
- The weak pull-up and pull-down resistors are activated or not depending on the value in the GPIOx\_PUPDR register
- The data present on the I/O pin are sampled into the input data register every AHB clock cycle
- A read access to the input data register gets the I/O state
- A read access to the output data register gets the last written value

Read TTL Schmitt registers triaaer protection Write register Input driver set/reset I/O pin Output driver  $V_{DD}$ on/off data P-MOS protection Output Output Read/write control N-MOS Push-pull or Open-drain ai15941b

Figure 19. Output configuration

#### **GPIO** example ST32F - Circuit

#### **Analog configuration**

- The output buffer is disabled
- The Schmitt trigger input is deactivated, providing zero consumption for every analog value of the I/O pin. The output of the Schmitt trigger is forced to a constant value (0).
- The weak pull-up and pull-down resistors are disabled
- Read access to the input data register gets the value "0"

